kubernetes 标签 Label 的使用
Label 标签是啥?
Label 是 kubernetes 的一个重要概念。它的作用就是在资源上添加标识,用来对它们进行区分和选择。
- 一个 Label 会以 key/value 键值对的形式附加到各种对象上,如 Node、Pod、Service 等。
- 一个资源对象可以定义任意数量的 Label,同一个 Label 也可以被添加到任意数量的资源对象上去。
- Label 通常在资源对象定义时确定,当然也可以在对象创建后动态的添加或删除。
可以通过 Label 实现资源的多纬度分组,以便灵活、方便地进行资源分配、调度、配置和部署等管理工作。
一些常用的 Label 标签示例如下:
版本标签:"version":"release", "version":"stable"......
环境标签:"environment":"dev","environment":"test","environment":"pro"
架构标签:"tier":"frontend","tier":"backend"
Label Selector 标签选择器
标签定义完毕之后,还要考虑到标签的选择,这就要使用到 Label Selector,即 Label Selector 用于查询和筛选拥有某些标签的资源对象
当前有两种 Label Selector:
1、基于等式的 Label Selector
name = slave
: 选择所有包含 Label 中 key="name" 且 value="slave" 的对象
env != production
: 选择所有包括 Label 中的 key="env" 且 value 不等于 "production" 的对象
# 列出包含 env 标签的所有 pod, 无论其值如何
$ kubectl get po -l env
# 同样列出没有 env 标签的 pod:
$ kubectl get po -l '!env'
注意确保使用单引号来包裹 !env
,这样 bash shell 才不会解释感叹号
2、基于集合的 Label Selector
name in (master, slave)
选择 key="name" 且 value="master" 或 "slave" 的对象
name not in (frontend)
选择 key="name" 且 value 不等于 "frontend" 的对象
标签的选择条件可以使用多个,将多个 Label Selector 进行组合,使用逗号 ,
进行分隔即可。
例如:
name=slave, env!=production
name not in (frontend), env!=production
命令方式打标签
为 pod 资源打标签
kubectl label pod nginx-pod version=1.0 -n dev
为 pod 资源更新标签
kubectl label pod nginx-pod version=2.0 -n dev --overwrite
查看标签
$ kubectl get pod nginx-pod -n dev --show-labels
NAME READY STATUS RESTARTS AGE LABELS
nginx-pod 1/1 Running 0 10m version=2.0
筛选标签
$ kubectl get pod -n dev -l version=2.0 --show-labels
$ kubectl get pod -n dev -l version!=2.0 --show-labels
删除标签
kubectl label pod nginx-pod version- -n dev
配置方式打标签
apiVersion: v1
kind: Pod
metadata:
name: nginx
namespace: dev
labels:
version: "3.0"
env: "test"
spec:
containers:
- image: nginx:latest
name: pod
ports:
- name: nginx-port
containerPort: 80
protocol: TCP
然后就可以执行对应的更新命令了
kubectl apply -f pod-nginx.yaml
将 pod 调度到特定节点
假设我们想部署一个需要 GPU 来执行其工作的新 pod。为了让调度器只在提供适当 GPU 的节点中进行选择,我们需要在 pod 的 YAML 文件中添加一个节点选择器。
只是在 spec 部分添加了一个 nodeSelector 字段。当我们创建该 pod 时,调度器将只在包含标签 gpu=true
的节点中选择
根据标签删除 Pod
$ kubectl delete po -l creation_method=manual